<!-- subpkg_consult/room/components/patient-info.vue -->
<script lang="ts" setup>
  import type { ConsultRecord, PictureElement } from '@/types/room'

  const props = defineProps<{ info?: ConsultRecord }>()

  // 患病时长
  const illnessTimes = [
    {
      type: 1,
      value: '一周内',
    },
    {
      type: 2,
      value: '一个月内',
    },
    {
      type: 3,
      value: '半年内',
    },
    {
      type: 4,
      value: '半年以上',
    },
  ]
  // 是否就诊过
  const consultFlags = [
    {
      type: 1,
      value: '就诊过',
    },
    {
      type: 0,
      value: '没有就诊过',
    },
  ]

  // 预览图片
  const onPreviewClick = (urls: PictureElement[]) => {
    uni.previewImage({
      urls: urls.map((item) => item.url),
    })
  }
</script>
<template>
  <!-- 患者信息（21） -->
  <view class="patient-info">
    <view class="header">
      <view class="title"
        >{{ props.info?.patientInfo?.name }} {{ props.info?.patientInfo?.gender ? '男' : '女' }}
        {{ props.info?.patientInfo?.age }}</view
      >
      <!-- 找医生极速问诊-患病时间1一周内2一月内3半年内4半年以上 -->
      <view class="note"
        >{{ illnessTimes.find((item) => item.type === info?.illnessTime)?.value }} |
        {{ consultFlags.find((item) => item.type === info?.consultFlag)?.value }}</view
      >
    </view>
    <view class="content">
      <view class="list-item">
        <text class="label">病情描述</text>
        <text class="note">{{ props.info?.illnessDesc }}</text>
      </view>
      <view class="list-item">
        <text class="label">图片</text>
        <text class="note" v-if="info?.pictures.length" @click="onPreviewClick(info?.pictures)"
          >点击查看</text
        >
        <text class="note" v-else> 暂无图片</text>
      </view>
    </view>
  </view>
</template>

<style lang="scss">
  .patient-info {
    padding: 30rpx;
    margin-top: 60rpx;
    border-radius: 20rpx;
    box-sizing: border-box;
    background-color: #fff;

    .header {
      padding-bottom: 20rpx;
      border-bottom: 1rpx solid #ededed;

      .title {
        font-size: 32rpx;
        color: #121826;
        margin-bottom: 10rpx;
      }

      .note {
        font-size: 26rpx;
        color: #848484;
      }
    }

    .content {
      margin-top: 20rpx;
      font-size: 26rpx;

      .list-item {
        display: flex;
        margin-top: 10rpx;
      }

      .label {
        width: 130rpx;
        color: #3c3e42;
      }

      .note {
        flex: 1;
        line-height: 1.4;
        color: #848484;
      }
    }
  }
</style>
